草庐IT

c++ - 递归 lambda 的 Typedef

全部标签

Ruby 1.9.3 Dir.glob 奇怪的递归匹配行为

假设目录结构为:a/b/c/d/e/f/g/h我试图通过以下方式找到“h”:Dir.glob('a/**/f/g/h')但是这不起作用。有什么想法吗?您可以尝试下面的测试用例:$/usr/bin/ruby-vruby1.9.3p194(2012-04-20revision35410)[x86_64-linux]$mkdir-pa/b/c/d/e/f/g/h$ruby-e"putsDir.glob('a/**/*')"a/ba/b/ca/b/c/da/b/c/d/ea/b/c/d/e/fa/b/c/d/e/f/ga/b/c/d/e/f/g/h$ruby-e"putsDir.glob('a

ruby - 从关联 block 中递归调用 Ruby 方法。还有别的办法吗?

我想出了这个:deffx,&byieldx,bendf4do|i,b|pifi-1,&bifi>0end结果:43210还有别的办法吗? 最佳答案 这取决于您的实际代码的细节,但根据您的示例,如果您预先命名block,则可以避免在函数中产生值和block。例如:deff(x,&b)yieldxendfoo=lambdado|i|pif(i-1,&foo)ifi>0endf(4,&foo)但是,我想找到一个更优雅的解决方案来解决这个问题。我怀疑这将是Y组合器的一个很好的应用。一旦我有更好的东西给你,我会更新这条消息。

ruby - yield 递归

所以我正在尝试做这样的事情:deffunc(x,y)ifx.length==1thenn=x.pop()yield(n,y)elsen=x.pop()yield(n,func(x,y))endend这样调用它:a=func([1,2,3,4,5],0)do|x,y|x+yend有没有可能做这样的事情?我一直没有得到任何阻止(yield)(LocalJumpError)。我什至尝试做一些不同的事情:deffunc(x,y)func(x,y)do|tail|..endend但没有运气谢谢。 最佳答案 是的,您可以显式地将block作为参

ruby - 如何在 ruby​​ proc/lambda 中使用真正的局部变量

初学者Ruby问题。更改此代码的最简单方法是什么,完整保留该block,从而消除副作用?x=lambda{|v|x=2;v}x.call(3)#=>3x#=>2这是我能想出的最简单的例子来说明我的问题,所以“删除分配”或“不要将Proc分配给x”不是我要找的。我想在Proc(或lambda)中设置局部变量,可以在不影响原始封闭范围的情况下对其进行赋值。我可以动态创建一个类或模块来包装block,但对于这样一个基本的东西来说,这似乎有点过分了。与我正在尝试做的等效的Python:defx(v):x=2#thisisalocalvariable,whataconceptreturnv

c - Ruby C 扩展开发人员的命名约定

在用C为ruby​​编写扩展时,我对遵循正确的命名约定很感兴趣。具体来说,我指的是将_p添加到谓词的函数名称以及为变量添加前缀m代表模块,c代表类等等。例如,如果我们想在C语言中定义一个像下面这样的谓词方法,我们应该在定义该方法的函数中使用_p作为后缀。classMyClassdefawesome?trueendend在C中:staticVALUEmy_extension_my_class_awesome_p(VALUEself){returnQtrue;}voidInit_my_extension(void){VALUEcMyClass=rb_define_class("MyClas

Ruby 左递归与右递归

出于某种原因,Ruby在面对左递归时似乎表现得更好。例如:defleft_recursive_factorial(number)return1ifnumber.zero?left_recursive_factorial(number.pred)*numberenddefright_recursive_factorial(number)return1ifnumber.zero?number*right_recursive_factorial(number.pred)end当我用超过9000(?)的值调用这些方法时,我得到不同的结果:left_recursive_factorial(900

ruby - 在 procs、lambdas 和 block 中返回语句

我很难理解return在block、过程和lambda中的工作原理。例如,在下面的例子中,为什么batman_ironman_proc有效,而batman_yield抛出错误?defbatman_ironman_procvictor=Proc.new{return"Batmanwillwin!"}victor.call"IronManwillwin!"enddefbatman_yieldyield"Ironmanwillwin!"endvictor=Proc.new{return"Batmanwillwin!"}putsbatman_ironman_proc#batman_yield(

ruby - 为什么 Enumerable#detect 需要 Proc/lambda?

Enumerable#detect返回block评估为true的数组的第一个值。它有一个可选参数,需要响应call并在这种情况下被调用,返回它的值。所以,(1..10).detect(lambda{"none"}){|i|i==11}#=>"none"为什么我们需要lambda?为什么我们不直接传递默认值本身,因为(在我的测试中)lambda无论如何都不能有任何参数?像这样:(1..10).detect("none"){|i|i==11}#=>"none" 最佳答案 与Ruby中的所有事物一样,“最小意外原则”适用。当然,这并不是说

ruby-on-rails - Rails 中的递归路由

是否可以在Rails中创建递归路由?我有一个应用程序,允许管理员创建页面。页面模型是一个嵌套集,因此每个页面都有一个parent_id因此页面以树的形式构建。页面模型还使用FriendlyID插件为每个页面提供slug。当用户浏览网站时,我希望他们看到url中的嵌套结构-这对于搜索引擎以及可能希望通过截断url浏览网站的任何用户来说更好。我想要的是:http://example.com/page/page/page/page...等等现在显然我可以创建一个嵌套map,比如10个嵌套,并希望没有站点超过该限制,但我很好奇是否有其他方法... 最佳答案

ruby - Ruby 中的递归文件列表

我是Ruby的新手(作为Java开发人员)并尝试实现一种方法(哦,抱歉,一个函数),该方法将递归地检索和生成子目录中的所有文件。我将其实现为:deffile_list_recurse(dir)Dir.foreach(dir)do|f|nextiff=='.'orf=='..'f=dir+'/'+fifFile.directory?ffile_list_recurse(File.absolute_pathf){|x|yieldx}elsefile=File.new(f)yieldfileendendend我的问题是:File.new真的打开一个文件吗?在Java中,newFile("xx